git 


(الأداة الأكثر استعمالاً لإدارة الاصدارات) 


"م. مختار سيّد صالح" ™- git commit‏ > $ 


تعلم )زو 


(الأداة الاکثر استعمالاً لادارة الاصدارات) 


م. مختار سیّد صالح 


جمیع الحقوق محفوظة للمولف 


ملحوظة: يسمح بتداول هذا الكتاب بحرتة تامّة وفق رخصة المشاع الإبداعي Creative‏ 
5 و على نيّة الصدقة سائلين المولى عر و جك الإخلاص و القبول 


(انقر هنا لقراءة النص القانوني الكامل للرخصة) 


القضيك ارو 


ما هي 1 

أ هي آداة تستخدمها فرق العمل بشکل عام و البرمجية منها بشکل خاص لإدارة إصدارات 
المشروع/العمل الذي یتعاون أعضاء الفریق على انجازه. 

و نعني ب 'إدارة الاصدارات" إمكانيّة تتبع التغییرات التي آجراها أعضاء الفریق على ملفات المشروع 
خلال مراحل تنفیذه المختلفة بحیث یمکن تحدید وقت و تاريخ کل تغيير إضافة لعضو الفریق 
المسوول المتسبب بهذا التغییر . 


كيف نشات git‏ و لماذا؟ 

يعتبر لينوس تورفالدز (منشئ نظام لينكس) الأب الروحي ل ا9ء و تعود أسباب نشأة أك إلى 
حاجة الفريق العامل على تطوير نواة لينكس حينها إلى أداة مناسبة لإدارة الإصدارات و صديقة 
لفرق عمل البرمجيات مفتوحة المصدر.ء خصوصاً بعد النزاع الذي نشأ بينهم و بين الشركة القائمة 
على تطوير نظام 9111666067 الذي كانوا يستعملونه وقتها (أبريل ۲۰۰۵) حيث أن الأخير 
مرخص تجاريّاً و بالتالي لاستخدامه من قبل مجتمع كبير من المطورین تبعات قانونية كانت سبباً 


في إشعال فتيل النزاع. ! 


لماذا تستخدم 016؟ 

كما ذكرنا في التعريف» فان الأهداف الرئيسية لاستخدام 914 تتلخص في: 
1. تسجيل التغييرات التي يجريها المطورون في شيفرات المشاريع البرمجية. 
2. تسجيل المتسبّب بك من تلك التغييرات و تاريخ كل منها. 


https: //en.wikipedia.org /wiki/Gi#History 1 


3 إتاحة إمكانيّة التعاون في المشاریع البرمجية بحيث يمكن لاکثر من عضو في الفریق 
العمل على نفس الملف/الملفات في نفس الوقت دون ضياع أَيّة مساهمات. 


تثبيت )01: 
تختلف آلية تثبيت 911 باختلاف نظام التشغيل المستخدم و فيما يلي التفاصيل: 
« أنظمة وندوز 170011/5//ا: يتم التثبيت من خلال معالج تثبيت !10751816 يمكن تحميله 
من موقع الأداة الرسمي. 
« أنظمة لينكس ×د”أا: باستخدام سطر الأوامرء و اتباع أمر التثبيت المخصص لكل 
توزيعة من توزيعات لينكس و التي مكن مراجعتها من خلال موقع الأداة الرسمي. 
« أنظمة ماك أو إس 2005: باستخدام ۱0۳6۲6۷ أو باستخدام معالج التثبيت الخاص 
بماك أو إس و الذي يمكن تحميله من موقع الأداة الرسمي. 
بعد اتباع تعليمات التثبيت الخاصة بنظام التشغيل الذي تعمل علیه يمكنك تجريب الأمر: 
git --version‏ 
في سطر الأوامر للتأكد من تثبيت الأداة حيث يفترض أن يظهر رقم الإصدار الذي تم تثبيته لو 


كما توضّح الصورة أدناه.2 
muktar — -zsh — 37x7‏ 5 © © © 


[/Users/muktar > git --version 
git version 2.35.1 
/Users/muktar > 


2 في متن هذا الكتاب سأستعمل سطر أوامر ماك أو إس ۵605 نظراً لأنني أكتب هذا الكتاب على ۳۲۵ ۰۷۵6000 لکن بشكل عام 


يمكنك استخدام سطر الأوامر المتاح في نظام التشغيل الذي تستعمله بنفس الأسلوب. 


تعریف حساب )زو المحلي 
قبل أن نبدأ باستخدام أو يفضصّل أن نقوم بتعریف الحساب المحلي الخاص بنا على ۰91 و ذلك من 
خلال تنفیذ الأمرين: 


git config --global user.name "Muktar SayedSaleh" 


git config --global user.email "muktar@monjz.com" 


بهذه الطريقة و عندما نقوم باستخدام 911 بعد قليل لحفظ أية تغييرات نقوم بهاء فستظهر تلك 
التغييرات على أنّ المتسبب بها هو المستخدم صاحب الاسم و البريد الإلكتروني الذين أدخلناهما 
أعلاه. 
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/Users/muktar > git config --global user.name "Muktar SayedSaleh" 
git config ~--global user.email "muktar@mon j 2۰ com" 


ملحوظة أولى: لا تنس تغيير اسم المستخدم وعنوان البريد في المثال أعلاه إلى اسم المستخدم 
الخاص بك و عنوان بريدك الإلكتروني. 

ملحوظة ثانية: كوننا استعملها الوسيط العام 910081-- فهذا يعني أن الحساب الذي قمنا بتعريفه 
سيكون هو الحساب المستخدم في جميع مستودعات 911 على هذا الحاسوب. ما لم نقم بتخصيص 
بعض المستودعات بغير ذلك صراحة: و سنأتي على ذكر معنى المستودع بعد قليل. 


۳3 


البد ء باستخدام git‏ 

و الآن» یمکننا البدء باستخدام اأ لادارة اصدارات المشروع الذي نعمل علیها حالياً» و ذلك من 
خلال الانتقال إلى مجلد المشروع ثمّ إدخال الأمر التالی كما تبيّن الصورة آدناه» و ذلك لتحوبله 
إلى مستودع ][۵» حيث أتنا نستخدم مصطلح مستود ع" 6005/00۲۷ للإشارة إلى أي مشروع تدار 


(صداراته باستخدام )او و آمر التهيئة هو: 


git init 
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[Desktop/git-book > git init 
Initialized empty Git repository in /Users/muktar/Desktop/git-book/.git/ 
Desktop/git-book - (master) > 


و بهذا نكون قد قمنا للتوّ بانشاء أوّل مستودع 915 بنجاح» مبارك مبارك! 


حالات الملفات في ]زع 

لقد أنشأنا مستودع او محليّاً في الفقرة السابقة» غير أنه فارغ و لا يحوي أَيّة ملات» لذا سنقوم 
بإنشاء ملف جديد (و ليكن ملف 171771 على سبيل التجریة)» ثم نقوم بحفظ ذلك الملف و إضافته 
إلى 011. 

فائدة: إذا لم تكن تعلم كيف تنشئ ملفات ۷۳۱ و أحببت أن تتعلم فيمكنك الرجوع إلى كتابي 
المنشور مسبقاً و الذي يشرح ذلك بالتفصيل» أما بالنسبة لهدف هذا الكتاب فيمكنك إنشاء أي ملف 


نصّي عادي إذا أحببت. 


على أيّة حال» سنستخدم لمثالنا في الشرح ملف ا١1۲‏ نضع به المحتوی التالي» و نحفظه باسم 
index.html‏ 


<html> 
<head><title> yi مرحباً بك‎ git!</title></head> 
مرحباً بك في<000<>۳1>‎ 9])1>/۱1<>/000۷< 
</html> 


و الآن إذا عدنا إلى سطر الأوامرء و استعرضنا الملفات الموجودة في مجلّدنا الجديد فيجب أن 


نری ملفنا 1006.۳۱ فقط كما تبيّنه الصورة التالية: 
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[Desktop/git-book - (master) > ls 
index.html 
Desktop/git-book - (master) > 


ملحوظة: في لينكس و ماك أو إس» يستخدم الأمر 5| لاستعراض الملفات الموجودة في المجلد» و 
يقابله الأمر ٣ك‏ في سطر آوامر ويندوز. 
حسناًء الآن يمكننا أن نتحقق من حالة تتبع الملفات في 911 باستخدام الأمر 


git status 


و الذي سنستعمله كثيراً ضمن صفحات هذا الکتاب» حيث يستعمل هذا الأمر لرؤية الوضع الحالي 
لملفات المشروع بالنسبة ل 911؛ و في مثالنا الحالي بما أنّ الملف جديد فسيظهره لنا أو على أنه 
ملف جديد لم يتم تتبعه بعد ۱01۲0660 و لم نقم بالاحتفاظ بأي |صدار" منه كما تبيّن لقطة 
الشاشة أدناه. 
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Desktop/git-book - (master) > git status 
On branch master 


No commits yet 


Untracked files: 


(use "git add <file>..." to include in what will be committed) 


nothing added to commit but untracked files present (use "git add" to track) 
Desktop/git-book - (master) > 


فبالنسبة ل 911 تكون الملفات الموجودة في مستودع ما على إحدى حالتين: 

۰ ۲۲۵26۷60: و تشير إلى الملفات التي يعرفها 914 و المضافة إلى المستودع من قبل. 

ه 0130160لا: و تشير إلى الملفات الجديدة التي لم ضف إلى المستودع بعد. 
و سنتعلّم بعد قليل الأمر المستعمل لنقل الملفات من حالتها غير المتتبعة إلى حالة التتبّع مروراً 
بمرحلة الإدراج» و هي ما سنناقشه في الفقرة التالية. 


مرحلة الادراج Staging‏ 

تمثل مرحلة الإدراج 51990179 الحالة التي تسبق مرحلة التتبّع مباشرة للملف الذي ننوي تتبّعه لأول 
مق أو تتبّع التغييرات التي تمت عليه لاحقاًء بما فيها حذفه. حيث لا يمكننا نقل الملف أو تغييراته 
من حالة عدم التتبع إلى حالة التتبع مباشرة دون المرور بمرحلة الإدراج. 

و الملفات المُدرّجة هي ملفات جاهزة للإيداع كمساهمة 601711711 في المستودع الذي تعمل علیه. 
وهو ما سنتعرض له بالتفصيل أثناء شرح عملية إيداع المساهمة 00۳0۳01 في الفقرة اللاحقة أما 
الآن و كوننا أتممنا العمل على الملف ۱006*.0101» فلنقم بإضافته إلى مرحلة الإدراج باستخدام 
الأمر 200 بالشكل التالي: 


git add index.html 


5 


و الآن إذا قمنا بتنفیذ آمر التحقق من حالة ازو (الأمر 51214005 أو) فسنری انتقال الملف من حالة 


عدم التتبع بشكل كي إلى حالة الادراج 58]30150 كما تبيّنه الصورة التالية: 
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[Desktop/git-book - (master) > git add index.html 
[Desktop/git-book - (master) > git status 
On branch master 


No commits yet 
Changes to be committed: 


(use "git rm --cached <file>..." to unstage) 
new file: lex.html 


Desktop/git-book - (master) > 


ملحوظة: يمكننا إضافة أكثر من ملف واحد إلى حالة الإدراج دفعة واحدة من خلال الأمر 911 
ااه-- 200 حيث أنّ الوسيط ااه-- يعني جميع الملفات. كما يمكننا إضافة مجلد كامل إلى حالة 


الادراج من خلال كتابة اسم المجلد بدلاً من اسم الملف عند تنفيذ تعليمة 300. 


ایداع المساهمات Committing‏ 

یعتمد 011 في إدارة الاصدارات على مفهوم المساهمات" و المساهمة ]00۳۱۲0 هي مجموعة من 
التعدیلات التي تتم على الملفات و التي تحفظ ككتلة واحدة في شجرة تاريخ 1أ9» بحيث تعتبر کل 
مساهمة )00۳0۳0 محطّة من محطات سير المشروع و يتيح ]زو العودة إلى أيّة محطّة مستقبلاً كما 
سنری . 

على أيّة حالة» لایداع مساهمة يجب أولاً إدراج جمیع التغییرات المطلوب إيداعهاء ثم و بعد الادراج 
09 يتم الإيداع في المستودع من خلال الأمر 00171011 مع مراعاة ترك رسالة مناسبة ترافق 
عملية الإيداع و تبين ما تم فيها بشكل مختصر عادة لسهولة المراجعة من قبل المساهم نفسه أو 
زملائه في فريق العمل. 

لإيداع العمل الذي قمنا به في الفقرة السابقة مع رسالة تفيد أنه أول إيداع نقوم بتنفيذ الأمر التالي: 


"بسم لله الرحمن الرحیم» الإيداع الأول" git commit -m‏ 


ینفذ الأمر ]60۳0۳01 عملية الإيداع» وتضیف "7655906" ۳0- رسالق و هکذا تکون بيئة الادراج 
قد آودعت في مستودعنا مع رسالة تقول 'بسم الله الرحمن الرحیم» الایداع الأول" كما یظهر في 
الصورة آدناه» و يلاحظ أنّ 911 يقوم تلقائياً بمنح ترقيم فريد لكل عمليّة إيداع» و يسمّى هذا الرقم 


'معرّف الإيداع" ۱0| .Commit‏ 
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[Desktop/git-book - (master) > git commit - لا ع الأول"‎ 

[(naster (root-comnit) f1d5d3e] بسم الله الرحمن الرحيم« الإيداع الأول‎ 
1 file changed, 8 insertions(+) 

create mode 100644 index.html 

Desktop/git-book - (master) > 


"بسم الله الرحمن الرحيمء. الإيداع 


ملحوظة: بالنسبة لإيداع التغييرات على الملفات التي سبق و أن أودعت من قبل تنفيذ مرحلة 
الإدراج بشكل ضمني أثناء القيام بعملية الإيداع من خلال تمرير الوسيط 2- بحيث تصبح التعليمة 
الكاملة كمايلي» مع نصيحتي بتحاشي استخدام هذه التعليمة لتفادي حالات إيداع ملفات غير 


مرغوب بإيداعها عن طريق الخطأ. 


git commit -am "Your commit message here" 


إيداع نفس الملف مرّة أخرى! 
حسناًء الآن بعد أن قمنا بإيداع الملف للمرة الأولى» فلنقم بعمل أيّ تغيير ضمن الملف 
۱006.۲ (کاضافة سطر مثلاً أو تغيير محتوى الجملة النصيّة) و ذلك بهدف رؤية كيف 


سيقوم ]او بالتعرف على التغيير الحاصل عند تنفيذ الأمر 5131005 زو كما توضحة الصورة آدناه؛ 


و يرجى ملاحظة کلمة 170011560 و التي تعني أن الملف مدرج سابقاً لکنه الآن خضع لتعدیل 


جعل نسخته الحالية معتلة 7001160" بمعنی ها مختلفة عن آخر إدراج تم لها في 1أ0. 
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1 file changed, 8 insertions(+) 
create mode 100644 index.html 
[Desktop/git-book - (master) > git status 
On branch master 
Changes not staged for commit: 
(use "git add <file>..." to update what will be committed) 


(use "gitrestore <file>..." to discard changes in working directory) 


no changes added to commit (use "git add" and/or "git commit ~a") 
Desktop/git-book - (master) > 


یمکننا الآن تکرار نفس خطوات عملية الایداع السابقة» و إجراء لیداع كان لنفس الملف مع رسالة 
تفید بسبب الایداع كما تبينه الصورة التالية: 
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[Desktop/git-book - (master) > git add . 
[Desktop/git-book - (master) > git commit ~0 "إضافة جملة جديدة إلى ملف الفهرس"‎ 
[master 80bfe88] إضافة جملة جديدة إلى ملف الفهرس‎ 
1 file changed, 1 insertion(+), 1 deletion(=-) 
Desktop/git-book - (master) > 


الاطلاع على سجل الإيداعات 
الآن و كوننا قمنا بعمل إيداعين في مستودعناء ریما يكون الوقت مناسباً لتجرية أمر الاطلاع على 
الإيداعات التي تمت بالفعل في المستودع من خلال تنفيذ الأمر: 


git log 


و الذي يعرض معرفات عملیات الإيداع السابقة و تاريخ كل منهاء و الرسالة التي تبيّن سبب 
الایداع كما آدخلها المستخدم الذي قام بعملية الایداع كما يظهر في الصورة آدناه مع ملاحظة أنّ 
ترتیب ظهور عملیات الایداع عكسي (من الأحدث للاقدم) 
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Desktop/git-book - (master) > git log 


Author: Muktar SayedSaleh <muktar@monj 2. com> 
0316۶: Thu Jun 9 11:23:44 2022 +080 


Author: Muktar SayedSaleh <muktar@monj Zz. com> 
036۶: Thu Jun 9 11:15:51 2022 90 


بسم الله الرحمن ا لإيدا ۳ 


Desktop/git-book master) > 


فائدة: يمكن بشكل اختياري تثبيت أداة اسمها اا9 تتيح لنا الاطلاع على السجلات من خلال 
واجهة استخدام مرئية الات توضحها الصورة التالية مع تأكيدي آتنا يجب أن نتعلّم 011 من خلال 
سطر الوامر لضمان الفهم الکامل لالية عملها و الاستفادة القصوی منها. 


4 ۰ git-book: ال۸‎ files - gitk 
إضافة جملة جديدة إلى ملف القهرس‎  Muktar SayedSaleh <muktar@monjz.com> 2022-06-09 11:23:44 
يسم الله الرحمن الرحيم. الإيداع الأول‎ Muktar SayedSaleh <muktar@monjz.com> 2022-06-09 1 
SHA1 IO: 80bfe889769808bdf26c8a7d422204bd9ee7054d4 € 3 Row 1/ 2 
Find YQ ^ commit containing: o Exact © 411 1045© 
وم‎ 0۵ Tree 
Comments 


O Diff Old version New version Lint pes hinl 


Author: Muktar SayedSaleh <muktarêr 
Committer: Muktar SayedSaleh <mukto 
۴۵۳۵۳۷۰: 68 
Branch: master 

Follows: 

Precedes: 


إضافة جملة جديدة إلى ملف الفهری 


index 5679634. .31239c8 100644 
60 -3,6 +3,6 8 
مرحیا بك فى<©116غ>‎ ۶ 
</head> 
<body> 


التراجع عن عملية ایداع في ]1ع 

یحدث أحياناً أن نقوم بعمليّة ایداع ما أو أكثرء ثم و لسبب أو لآخر نکتشف آننا بحاجة للتراجع عن 
عملية الایداع تلك» تتيح ]91 التراجع عن عملیّات الایداع بأسلوبین اثنين آحدهما بسیط و سنناقشه 
في هذه الفقرق و الآخر متقدم سنناقشه في الفصل الرابع من هذا الكتيّب بإذن الله تعالی. 

أمَا الأمر البسیط فهو أمر ۲6۷6۲۵ 911 و الذي یقوم بالتراجع عن عملية إيداع معيّنة من خلال 
القيام بعملية إيداع أخرى معاكسة تماماً بحيث تكون النتيجة العودة بالملفات إلى حالتها التي كانت 
عليها قبل عملية الإيداع الأساسية التي نرغب بالتراجع عنها. 

و لكي نفهم الأمر بشكل عملي» لنقم بالتراجع عن عملية الإيداع الثانية التي قمنا بها في الفقرة 
السابقة و التي قمنا بموجبها بإضافة بعض الكلمات إلى ملف ۳۸۳۲۱ الذي آنشآناه» و للقيام بهذا 
الغرض نحتاج لمعرفة معرّف عملية الإيداع 10 ]0000۳0 المطلوب التراجع عنها و الذي يمكننا 
ببساطة نسخه ممّا يولده الأمر 109 أو كما تظهر الصورة أدناه 
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[Desktop/git=b ook (master)_=>git—oyg 


Author: Muktar ۹۵۷6055 ]6۳ <îmUKTtar@mon j 2 . 2 
036: Thu Jun 9 11:23:44 2022 +0 
إضافة جملة جديدة !إ‎ 


,لى 


ملف الفهرس 


Author: Muktar SayedSaleh <muktar@mon j 2. com> 
036: Thu Jun 9 11:15:51 2022 +0 


بسم الله الرحمن الرحيمء الإيداع الاول 
Desktop/git-book - (master) >‏ 


نم تنفيذ الأمر التالي مع مراعاة استبدال <10-][00۳0۳0> بمعرف عملية الإيداع : 


git revert <commit-id> 
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Author: Muktar SayedSaleh <muktar@mon j Zz. com> 
Date: Thu Jun 9 11:23:44 2022 +0300 


إضافة جملة جديدة إلى ملف الفهرس 


Author: Muktar SayedSaleh <muktar@mon j Zz. com> 
Date: Thu Jun 9 11:15:51 2022 +0300 


بسم الله الرحمن الرحیم» الإيداع الأول 
Desktop/git-book - (master) > git revert 80bfe889769808bdf26c8a7d422204bd9ee7054d‏ 


8 ۴ 
إضافة جملة جديدة 


[naster b43f4dd] Revert إلى ملف الفهرس"‎ 
1 file changed, 1 insertion(+), 1 deletion(-) 
Desktop/git-book - (master) > 


فائدة: 911 ذكي كفاية لمعرفة عملية الإيداع المقصودة بمجرّد إدخال أوّل ۸ أحرف من معرّف 


العملية إذا كنت لا ترغب بنسخ كامل المعرّف. و هذا ينطبق على جميع الأوامر التي تستقبل 


commit 0‏ و منها الأمر .rever†‏ 


الفصل الثاني 
التفریعات Branches‏ 


ما هي التفریعات branches؟‏ 

يحدث في معظم الأحيان عند العمل ضمن فرق العمل أن یکون كل عضو أو مجموعة أعضاء من 
الفريق مسؤولين عن تطوير جزء مستقل و منفصل من المشروع» و لهذا الغرض قد يرغب هؤلاء 
بالعمل على نسخة شبه مستقلّة من المشروع بحيث يتاح لهم أخذ الوقت الكافي للتطوير دون التأثير 
على باقي أعضاء الفريق» و هذا تماماً ما يتم استخدام التفريعات 8۲206065 من أجله في أأو. 
بمعنى آخرء تسمح الفروع للمطورين بالعمل على أجزاء مختلفة من المشروع دون التأثير على الفرع 
الرئيسي» و عند تمام العمل يُدمج الفرع الجديد مع المشروع الرئيسي» بل تستطيع التبديل بين 
الفروع و العمل على مشاريع مختلفة دون أن يؤثر كل منها على الآخرء فاستخدام أسلوب التفريع 
هنا طريقة سريعة و خفيفة لإجراء التعديلات على المشروع. 


إنشاء فرع جديد في )81 
لنضف الآن بعض المزايا الجديدة في صفحة .10067 التي أنشأناها في الفصل السابق» و 
كوننا نرغب أن نقوم بهذا في مستودعنا المحلي دون التأثير على المشروع الرئيسي أو تعطيله 


سنقوم بإنشاء فرع جديد باستخدام الأمر 0۲۵۳6 ]01: 
git branch ۱۵۱۱۵۰۸۷۵۲۱-5‏ 
لقد أنشأنا الآن فرعاً جديداً 0۲۵0600 باسم 06/۱0-۵۲۱-29210, و یمکننا أن نتحقق من وجوده 


من خلال تنفيذ الأمر 5080601 911 (دون تمرير اسم أي فرع) مرة أخرى 
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[Desktop/git-book - (master) > git branch hello-world-images 
[Desktop/git-book - (master) > git branch 


hello-world-images 
2 master 
Desktop/git-book - (master) > 


كما نری فیوجد الآن فرع جدید باسم ۱60-۷۷/0۲۱0-۳۵985» و فرع آخر اسمه ۲۱25/6۲ و 
بجانبه علامة نجمة * تعني آننا الآن في هذا الفرع (في الفرع /723516) و ریما تتساءل الآن من 
أين جاء الفرع ۱25/6۲ و آنا أتعلّم التفريعات للتق؟ و الجواب أنّ 916 تنشئ الفرع 0۵2506۲ بشکل 
آلي في كل مستودع جدید. 

فائدة: بعض توزیعات ]9 تستخدم الاسم ۲210 بدلا من master‏ لتلافي الإيحاء التاريخي الذي 


يعنيه لفظ السیّد ۲۱۵5/6۲ في بعض الثقافات الغربية. 


تنبیه: يجب الانتباه إلى الفرع الذي تتواجد فيه لحظة إنشاء فرع جديدء لأن الفرع الجدید سیکون في 
لحظة انشائه نسخة مطابقة تماما للفرع الذي تم إنشاؤه منه. 


الانتقال إلى فرع آخر في )3ع 
يُستخدم الأمر 606000۱ للانتقال من الفرع الحالي إلى فرع آخر نمرّر اسمه مع الأمرء و لتجرية 
ذلك یمکننا الانتقال إلى الفرع الجدید الذي أنشأناه توا كمايلي: 


git checkout hello-world-images 
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[Desktop/git-book - (master) > git checkout hello-world-images 


Switched to branch 'hello-world-images ' 
Desktop/git-book - (hello-world-images) > 


و هكذا نكون قد نقلنا مساحة العمل الحالية من الفرع الرئيسي إلى الفرع الجديدء و الآن لنفتح 
محرراً نصياً لنجري بعض التعديلات. 


فائدة: یمکننا استخدام الخیار 0- مع الامر ادا60661 لنطلب من ]زو أن بنتقل إلى الفر ع الجدید في 
حال كان موجوداًء و الا أن ينشئه ثم ینتقل إليه مباشرة. 


في هذا المثال سنقوم باضافة اسمها 0110.[09/لا_170_17©|!9! إلى مجلد العمل ثمّ نضمنها ضمن 
صفحة 1۱06۰۲۱۲۳۱ بإضافة السطر التالی: 

<img src="img_hello_world.jpg" 2112۳16۱۱0 World from Space" />‏ 
و بهذا نكون قد أجرينا تغييرات على ملف 006.۲۱ و أضفنا الملف الجديد 


9 -۱6۱0_ و۱۳۲ إلى مجلد العمل» و إذا نفذنا 50215 011 سنجد مايلي: 
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Desktop/git-book - (hello-world-images) > git status 
On branch hello-world-images 
Changes not staged for commit: 
(use "git add <file>..." to update what will be committed) 
(use "git restore <file>..." to discard changes in working directory) 


Untracked files: 
(use "git add <file>..." to include in what will be committed) 


no changes added to commit (use "git add" and/or "git commit ~a") 
Desktop/git-book - (hello-world-images) > 


و کما تلاحظ فالملف 1006.1۱ يحوي بعض التعدیلات (27001160) غير أنه لم يُدرج بعد 
.NNot staged‏ و أمّا الملف ۱۷۵۲۱۵.[09 6۱0_ و۱۳ فحالته 7130160الا کونه يضاف للمرة 
الأولى و لم يودع من قبل» و للقيام بايداع كلا التغييرين سنحتاج إلى إضافة كلا الملفين إلى بيئة 
الإدراج لهذا الفرع: 


git add --all 


و للتذكير فقط استخدمنا ااة-- بدلاً من آسماء الملفات المستقلة لادراج جميع الملفات بتعليمة 


واحدق» و الآن لو قمنا بالتحقق من حالة المستودع فسنری ما توضحه الصورة التالية: 
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[Desktop/git-book - (hello-world-images) > git add -- 1 
Desktop/git-book - (hello-world-images) > git status 
On branch hello-world-images 
Changes to be committed: 
(use "git restore --staged <file>..." to unstage) 
new file: img_he llo_wor ld. png 
modified: index.html 


Desktop/git-book - (hello-world-images) > 


تمرين: لماذا يظهر كلا الملفين باللون الأخضر الآن؟ 


حسناًء إذا كتا جاهزين لإيداع هذه التعديلات يمكننا إيداعها باستخدام الأمر 60۳۳۳ او الذي 


تعلمناه سابقاً مع ترك رسالة مناسبة توضح الهدف من عملية الإيداع: 


git commit -m "Added image to index.html" 


ما يهمنا الآن و نريد التركيز عليه هو وجود فرع 0۲200 جديد يختلف عن الفرع الرئيسي 
۲ و الاختلاف يمكن في عملية الإيداع الأخیرة» و لنرى الآن مدى سرعة وسهولة العمل مع 
الفروع المختلفة ومدى كفاءتها في العمل. نحن الآن في الفرع ۳۲2995[-۰6۱۱0-۷/0۲۱۵ وأضفنا 
صورة إلى ذلك الفرع و إذا استعرضنا الملفات التي في المجلد الحالي سنجد الملفين ۳06.0۵۱ 
و ۷۷0۲0.[09 6۱0_ ۱۳9 بمعنى آتنا نستطيع الآن رؤية الملف الجديد 
۷۵۲۱۰9 ۳6۱0_و۳» وكذلك نستطيع رؤية التغييرات الحادثة في الشيفرة إذا فتحنا ملف 


اindex.htn»‏ وهو ما نتوقعه تماماً. والان» لنری ما يحدث عند تغيير الفر ع إلى /5725161. 


git checkout master 
لم تعد الصورة الجديدة جزءاً من هذا الفرع و لو استعرضنا الملفات الموجودة في المجلد الحالي مرة‎ 
۳06۰/۵۳0۱ أخرى لرأينا الآن أن الصورة الجديدة غير موجودة و كذلك الشيفرة التي أضفناها إلى‎ 


و هذا يرينا سهولة العمل مع الفروع وكيف آنها تسمح بالعمل على أشياء مختلفة في نفس الوقت! 
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[Desktop/git-book - (master) > ls 

index.html 

[Desktop/git-book - (master) > git checkout hello-world-images 
Switched to branch 'hello-world-images ' 

[Desktop/git-book - (hello-world-images) > ls 

img_hello_world. png index.html 

Desktop/git-book - (hello-world-images) > 


فرع الإصلاحات الطارنة Hot fixes‏ 

لنتخيل الآن آننا لم ننه العمل على الفرع ۰۱۵۱/0-۷0۲۱0-1۳02965 لکتنا و لسبب هام نريد 
إصلاح خطأ طارئ في الفرع الرئيسي ۱۱2516۲ دون المساس بذلك الفرع الرئيسي ولا فرع ۲6۱/0 
9 مبمبما آننا لم ننه العمل عليه بعد» في تلك الحالة يمكننا ببساطة إنشاء فرع جديد 
للتعامل مع هذا الاصلاح الطارئ و يمكننا تسميته “101-11 اصطلاحاً: 


git checkout -0 hot-fix 


و نكون الآن قد أنشأنا فرعاً جديداً من الفرع الرئيسي و أجرينا تعديلات علیه» و نستطيع الآن 
إصلاح الخطأ دون التأثير على الفروع الأخرى» و كما تتوقع سيتم الأمر بإصلاح الأخطاء ثم إيداع 
هذا الإصلاح في الفرع الجدید» و لكن كيف نجلب هذا الإصلاح إلى الفرع الرئيسي؟ الجواب من 
خلال دمج الفرعين و هو ما سنناقشه في الفقرات التالية. 


دمج الفروع في Git‏ 


على فرض أن الخطأ الذي أصلحناه في الدرس السابق أصبح جاهزاً للدمج؛ يمكننا الآن أن نقوم 
بدمج الفرع »101-11 مع الفرع ۲۱2516۲ باتباع الخطوتين التاليتين: 


۳5 


« الانتقال إلى الفرع الهدف (/73516) الذي نرغب بدمج الفرع الآخر معه من خلال تعليمة 
.git checkout ۲‏ 
٠‏ دمج الفرع الآخر *-]00 مع الفرع الهدف من خلال الأمر .git merge hot-fix‏ 
في حال كون كل شيء على ما يرام سيتم الدمج و ستظهر المساهمات التي قمنا بها في فرع 
الإصلاحات العاجلة ضمن الفرع الرئيسي كما تبين الصورة أدناه. 
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[Desktop/git-book - (hot-fix) > git checkout master 
Switched to branch 'master' 

[Desktop/git-book - (master) > git merge hot-fix 
Updating b43f4dd..ef2be67 

Fast-forward 


img_hello_world.png | 0 

index.html ۱ 2 4 

2 files changed, 1 insertion(+), 1 06161100 1)-( 

create mode 100644 img_hello_world. png 
[Desktop/git-book - (master) > git log 


حذف الفروع في ]81 
في حال لم نعد بحاجة إلى فرع ما لأي سبب كان فيمكننا حذفه من خلال الأمر 


git branch -D branch_name 


حيث يمثل ۲4٥۸_٣4۳٠‏ اسم الفرع المطلوب حذفه»ء و يراعى أن يكون الحرف الوسيط 5 
بالحالة الکبیرة» كما تبين الصورة أدناه. 
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[Desktop/git-book - (master) > git branch -D ۵-۷ 
Deleted branch hot-fix (was 052b7fe). 
[Desktop/git-book - (master) > git branch 
hello-world-images 

x mas ۲ 


Desktop/git-book - (master) > 


تعارض عملیات الدمج Merge conflicts‏ 

في الفقرة قبل السابقة» تمت عملية دمج الفرعین بشکل سلس و دون مشاکل و ذلك نظراً لعدم وجود 
أكثر من شخص یعملون على نفس الملفات في الوقت نفسه لکن أحياناً و عند العمل ضمن فریق؛ 
لا تکون الأمور بهذه البساطة. و لا یستطیع او أحياناً معرفة الطريقة المثلی لدمج مساهمات 
المساهمین عندما یتصادف وجود تعدیلین أو آکثر في نفس الملف و في نفس الأسطرء عندها 
یحدث ما یسمّی بتعارض الدمج ]60۳6 ۵۲96 و الذي يتطلب التدخل اليدوي من أحد 
المساهمین للقيام بعملية حل التعارض ۲650۱۷۶ 00171101) بحیث یمکن إتمام الدمج بسلاسة. 

و لشرح هذه الحالة لا بد من اصطناع حالة تستوجب التعارض أولاً» ثمّ سنری معاً كيف یحدث 
التعاروض؛ و الأهم كيف يمكن حله! 

حسنا» لاختلاق حالة التعارض قم بعمل فرع جدید شم عدّل السطر رقم 5 مثلاً من ملف 
1.1701 في نفس الفرع الحالي» و قم بحفظ المساهمة ثم انتقل إلى الفرع الجدید و قم بتعدیل 
مختلف في نفس السطر و في نفس الملف (السطر ه من الملف ۱۳06.۳0/۳۱) ثم قم بحفظ 
المساهمة. 

الآن عندما تعود إلى الفرع الرئيسي و تحاول دمج الفرع الجديد سيظهر التعارض و سترى كلمة 
001101 أمام الملفات المتعارضة كما تبيه الصورة التالية: 
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Desktop/git-book - (master) > git merge branch1 
Auto=merging_index. html 

CONFLICT ontent) DMerge conflict in index.html 

Automatic merjé failed; fix conflicts and then commit the result. 
Desktop/git-book - (master) > 


حل التعارض Conflict Resolve‏ 
حسناً كما رأينا في الفقرة السابقة فقد حصل تعارض عندما حاولنا دمج الفرعین معا نتيجة لحقيقة 
آننا قمنا بإجراء تعدیلات مختلفة في نفس الأماكن من نفس الملفات و بالتالي لن یستطیع ][9 
تحدید طريقة لدمج المساهمات معا بشکل آلي في الملفات المتأثرة بالتعارض, یمکننا من خلال 
الشر 5131105 ]او معرفة الملفات التي تحوي تعارضات حيث سیظهرها و و بجانبها وصف 


60 001 بمعنی أنّ الملف خضع لتعدیل في كلا الفرعین» كما يظهر في الصورة آدناه. 
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You have unmerged ۰ 
(fix conflicts and run "git commit") 
(use "git merge --abort" to abort the merge) 


Unmerged paths: 
(use "git 388 <file>..." 6 Trark. resolution) 


no changes added to commit (use "git add" and/or "git commit ~a") 
Desktop/git-book - (master) > 


لو قمنا الآن بفتح الملف المتأثر باستخدام المحرر النصي» سنجد أنّ 911 قام بوضع علامات تحدد 
مناطق التعارض ضمن الملف متوقعاً منا القيام بتعديلات يدوية على الملف لحل التعارضات» و 
من الجدير بالذکر أن بعض المحررات النصيّة المتقدمة تسهّل عمليّة حل التعارضات البسيطة من 


خلال بعض الأدوات كما في حالة 0006 ۷5 مثلاً كما يظهر في الصورة آدناه. 


یمکننا بوضوح روية أن )زو ترك التعدیلین المتعارضین مع إشارة واضحة لاسم الفرع الذي جاء منه 
كل تعدیل (0620 يعني الفرع الذي نحاول الدمج الیه» 025/6۲ في مثالنا أعلاه). 

و الآن یمکننا إبقاء التعدیل المطلوب و حذف التعدیل غير المرغوب به لیعود الملف إلى حالة 
طبيعية. ثمّ نقوم بعد ذلك بعمل التعلیمات 200 او للملفات التي تم تعدیلها و حل التعارضات 
فيهاء ثم التعليمة 16ا00۳10- ۲۵۲96 011 كما تظهره الصورة آدناه. 
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Unmerged paths: 
(use "git add <file>..." to mark resolution) 


no changes added to commit (use "git add" and/or "git commit ~a") 
[Desktop/git-book - (master) > git add index.html 
Desktop/git-book - (master) > git merge --continue 

[master c148406] Merge branch 'branch1' 

Desktop/git-book - (master) > 


بهذا نكون قد غطينا الأوامر الأساسيّة في 916 للتعامل مع المستودع محليّاً (على الحاسب الخاص 
بنا)» و سنقوم في الفصل القادم بشرح كيفية التعامل مع مستودع بعيد مستعرضين منصة Gi‏ 
كمثال على منصّات او البعيدة» مع الإشارة إلى أنّ غالبيّة ما سنغطیه عند الحديث عن طداالان6 
ينطبق على جميع المنصّات الشهيرة مثل 51۳۱1061 أو .GitLab‏ 


الفصل الثالث 


مدخل إلى ں۸1 Git‏ 


Distributed أداة عمل موزع‎ git 

صممّت 911 في الأصل لتتيح لأعضاء فرق العمل المساهمة بشكل مستقلٌ تماماً بحيث يملك كل 
عضو من أعضاء الفريق نسخته الخاصّة 01006 من المستودع الخاص بالمشروع الذي يتم العمل 
عليه» ثمّ عند الحاجة لدمج المساهمات القادمة من مساهمين مختلفين يعملون على أكثر من جهاز 
يمكن الاعتماد على مستودع بعيد 11807016 واحد أو أكثر يكون بمثابة المصدر الموثوق للشيفرة 
اصطلاحاً 1۵1 01 5010166 مع أنه في نهاية المطاف ما هو لا نسخة 010076 من المستودع 
لتنظيم هذه العملية و تسهيلها ظهرت مجموعة من المنصّات أشهرها GitHub‏ و BitBucket‏ و 


۵10 و سنقوم في هذا الفصل بالحديث عن ۲۳۲ا بشكل مفصّل. 


تنبيه: كثيراً ما يستعمل المبتدئون نا!!]أ6 للإشارة إلى 916 أو العكسء مع آتهما شيئآن مختلفان 


تماماً تماماً كما سبق و أوضحناء لذلك أرجو توخّى الدقّة عند استعمال المصطلحات. 


تسجيل حساب جديد في اں Gi]‏ 

تسجيل الحساب في لانا!!أ بسيط و مباشر و كل ما تحتاجه هو الانتقال إلى الموقع 
0 ۱ ثم الضغط على زر لا 590 ثم تقوم بملء النموذج و تسجيل الحساب بشكل 
تقليدي» و رنما تكون التوصية 
الوحيدة التي أنصح بها هنا هي 
تسجيل الحساب بنفس عنوان البريد 


Where the world 
builds software 


الذي استخدمناه في تهيئة ]01 في 
الفصل الأوّل. 


انشاء مستودع على 6210۳100 
بعد تسجیل الحساب یمکننا إنشاء مستودع على 6۵۳۱0 مباشرة من خلال اختیار Create new‏ 


repository‏ و ملا تفاصیل المستودع (اسمه و وصفه .. إلخ) كما تبین الصورة آدناه, 


Pull requests Issues Marketplace Explore 


Owner * Repository name * 

0 MukhtarSayedSaleh + / git-book ۳ 
Great repository names are short and memorable. Need inspiration? How about upgraded-umbrella? 
Description (optiona! 


( The Example Repository Used In My Git Book 


عناضام ل © 


Add a README 


Add .gitignore 


أهمَ خيار رتّما في هذه الشاشة هو خيار جعل المستودع خاصّاً ۳۲۱۷۵۱6 أو عامّاً ©أاطناتاء حيث 
أنّ جعل المستودع عاماً ۳۷0۳۱0 يعني أته أصبح متاحاً لكل الناس للاطلاع علیه» و نسخه؛ و 
المساهمة فيه حثی إذا لم تضبط بعض إعدادات الحماية. 

الآن نضغط على زر ۲۵005/000 2۳6۵16 لإتمام إنشاء المستودع البعيد على 011۳0 و خلال 
زمن لا يذكر سننتقل آلياً إلى صفحة المستودع الذي قمنا بانشائه» و لعل أهمّ ما في الصفحة في 
هذه المرحلة هو رابط المستودع البعيد الذي يظهر في الصورة أدناه و الذي سنستعمله بعد قليل 
لمزامنة مستودعنا المحلّي الذي أعددناه سابقاًء مع المستودع البعيد الذي أنشأناه للتوّ. 


Quick setup — if you've done this kind of thing before 


Ci) set up in Desktop or HTTPS SSH https://github. com/MukhtarSayedSaleh/git-book.git 


5۳۷ Include a README, LICENSE, and .gitignore. 


Get started by creating a new file or uploading an existing file. We Teco 


تعریف المستودع البعید محليّاً 

لمزامنة المستودع المحلّي الذي آعددناه في فقرة سابقة على حاسوبنا الشخصي, مع المستودع البعید 
الذي أنشأناه لتق على 0۵1۳10 نحتاج إلى تعریفه ضمن المستودعات البعيدة محليّاًء و يتم ذلك 
من خلال الأمر remote‏ اأ كما يلي: 


git remote add <remote-name> <github-repo-url> 


حيث يعبّر ۲٠۴۳٠١۴-٣4۳6‏ عن الاسم الذي سنسمّي به المستودع البعيد (عادة يسمّى 0ا0۲19) 
بينما يعبّر |1لا-91]1008-1620 عن رابط المستودع البعيد الذي رأيناه في الفقرة السابقة» و لإضافة 


مستودعنا البعيد إلى المحلّي يصبح الأمر: 


git remote add origin https://github.com/MukhtarSayedSaleh/git-book.git 


و الآن يمكننا استعراض المستودعات البعيدة من خلال الشر ۷- ۲6۳016 اأو للتأكد من أنّ 


المستودع أضيف بشکل صحیح كما یظهر في الصورة آدناه. 


© © © ۳ 911-90001 — -zsh — 89x10 


[Desktop/git-book - (master) > git remote add origin https://github. com/MukhtarSayedSaleh/] i 
git-book.git 

Desktop/git-book - (master) > git remote -v 

origin https://github. com/MukhtarSayedSaleh/git-book.git (fetch) 

origin https://github.com/MukhtarSayedSaleh/git-book.git (push) 

Desktop/git-book - (master) > 


ارسال تعدیلاتنا المحليّة إلى المستودع البعيد و۳ 
یصطلح في أأو على استخدام الفعل دفع 05/0 للتعبیر عن إرسال التعدیلات المحليّة إلى 
المستود ع البعید» و كثيراً ما يقال 'ندفع التعدیلات" بمعنی أنّ نزامنها مع المستودع البعید من خلال 


الأمر دا5لام. 
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الآن مستودعنا البعيد 011917 و الموجود على طالا1!!]أ© لا يحوي أَيّة ملفات كونه أنشئ للتوّء لذلك 
يمكننا مزامنة التعديلات الموجودة محليّاً معه من خلال تنفيذ الأمر 09/1917 اكام او (بمعنى أننا 
سندفع التعديلات المحليّة إلى المستودع البعيد ذي الاسم 0/1917) كما في الصورة أدناه. 


© © © 55 911-0001 — -zsh - 2 


[Desktop/git-book - (master) > git push --set-upstream origin ۲۳ 
Enumerating objects: 23, done. 

Counting objects: 100% (23/23), done. 

Delta compression using up to 16 threads 

Compressing objects: 100% (20/20), done. 

Writing objects: 100% (23/23), 2.13 KiB | 1.07 MiB/s, done. 


Total 23 (delta 8), reused 0 (delta 0), pack-reused 0 
remote: Resolving deltas: 100% (8/8), done. 

To https://github.com/MukhtarSayedSaleh/git-book.git 
* [new branch] master -< master 

branch 'master' set up to track 'origin/master'. 
Desktop/git-book - (master) > 


و بمجرّد تنفیذ الأمر ستظهر الملفات على انا!]]أ6 كما تظهر لقطة الشاشة آدناه. 


© 8 © O توراه امكل رمق ماهد‎ x 
ج‎ 6 6 github.com/MukhtarSayedSaleh/gît-book û * © 5 4 ۸ > 0 94 ِ 
© arch or jump ۱ Pull requests Issues Marketplace Explore تح .+ بي‎ 

9 MukhtarSayedSaleh / git-book Public سنا‎ 1 - ۵ f ster 0 
<> Code © Issues 11 Pull requests © Actions [FH Projects CO Wiki O Security l< Insights $ Settings 
كل‎ master - | فق‎ 1branch ©0 tags Goto file  Addfile> About 8 
The Example Repository Used In My Git 
é MukhtarSayedSaleh Merge branch 'branch1' c148406 33 minutes مود‎ ©8 commits Book 
[Û img_hello_world.png 23 hours a9 f 0 stars 
© ۷ hing 
O index.html Merge branch 'branchî 33 minutes ago 
¥ > 
Help people interested in this repository understand your project by adding a README 
Releases 


releases published 
Greate ۵ new release 


Packages 


Publish 


Languages 


س 
HTML 1C‏ ۰ 
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تعدیل الملفات في ]0101 مباشرة 

یتیح تالا0[1۳۱) لمن برغب واجهة ويب لتعدیل الملفات مباشرة ضمن الموقع و دون الحاجة 
لمغادرته» و بحیث يتم حفظ المساهمات (التعدیلات) التي تتم ضمن 0لا! 6211۳ کمساهمة مباشرة 
على المستود ع البعید» و لتجرية ذلك نضغط على أحد الملفات ثم نختار آمر التعدیل الظاهر في 
الصورة آدناه. 


9 MukhtarSayedSaleh / git-book Public 9 Unwatc 61م‎ - ۲ Fork û f Star 0 ~~ 
<> Code O Issues 11 Pull requests ® Actions 0 Projects [CO Wiki O Security ععا‎ Insights $ Settings 

} master - git-book | index.html Go to file 

j MukhtarsSayedSaleh Merge branch 'branchî Latest commit 148405 42 minutes مود‎ O History 


AR 1 contributor 


د نقوم اجراء بعض التعدیلات و نختار الحفظ و سیطلب منا 611۳40 إفكال رسالة المساهمة 
المناسبة (۳۱۵55296 00۳0۳) و حفظ التعدیل کمساهمة جديدة 00101011 و کأتنا قمنا بذلك 
من خلال الأمرين 200 915 و 00101716 ]زو كما نفعل عادة! 


۸ Commit changes 


جلب تعدیلات المستودع البعید إلى المستودع المحلّي ۳011 

یصطلح في أ على استخدام الفعل سحب االام للتعبیر عن طلب التعدیلات البعيدة و جلبها إلى 
المستود ع المحلّيء و كثيراً ما يقال تسحب التعدیلات" بمعنی أنّ نزامن المستودع المحلّي مع 
التحدیثات التي دفعت على المستودع البعید من قبل زملاء العمل» و لتجرية ذلك فلنقم بجلب 
التعدیل الذي أجريناه على المستودع البعید (مستودع 011۳00) في الفقرة السابقة إلى المستودع 
المحلّي و ذلك من خلال تنفیذ الأمر االام 911 كما توضح الصورة آدناه. 


© © © 55 9-9001 — -zsh — 89x13 


[Desktop/git-book - (master) > git pull 

remote: Enumerating objects: 5, done. 

remote: Counting objects: 100% (5/5), done. 

remote: Compressing objects: 100% (3/3), done. 

remote: Total 3 (delta 1), reused 0 (delta 0), pack-reused 0 
Unpacking objects: 100% (3/3), 798 bytes | 266.00 KiB/s, done. 


From https://github.com/MukhtarSayedSaleh/git-book 
c148406..c4d98de master -> origin/master 
Updating c148406. .c4d98de 
Fast-forward 
index.html | 3 ++ 
1 file changed, 2 insertions(+), 1 deletion(-) 
Desktop/git-book - (master) > 


ملحوظة: أحياناًء و إذا كان ثمّة تعديلات على المستودع البعيد لم يتم سحبها بعد» فلن يسمح لك 


زو بالقيام بعمل دفع 0۱05/0 و سيطلب منك سحبها أولاًء و قد تحدث أثناء ذلك تعارضات تتطلّب 


الحل بنفس الأسلوب الذي استعرضناه في الفصل الماضي. 


إنشاء الفروع 131211165 في منصه GitHub‏ 
نستطيع إنشاء فرع جديد للمشروع الذي نعمل عليه في منصة 0د61 بالدخول إلى المستودع 
البعيد الخاص بنا و النقر على زر الفرع الرئيسي ۱2516۲ نم كتابة اسم الفرع الجديد مع الحرص 


على كتابة اسم يصف الفرع و الهدف منه»ء ثم ننقر على زر :Create 5/2۸٥۸‏ 


۲۶ master + } 1۵۲۵86۲ 0 tags 


Switch branches/tags x 
مباشرة و‎ 
test-branch| 
Branches Tags 
ی‎ Create branch: test-branch from ‘master’ 
View all branches lerstand 


ينبغي للفرع ۱65-۸ أن يكون قد أنشئ الآن و صار نشطاًء و نستطيع معرفة أي الفروع 
نحن فيها بالنظر إلى زر الفرع كما في الصورة آدناه» حيث نرى أنه يذكر أننا في الفرع ۲۱2506۲ 


[5 ۵5۱۵۲ ۶ كر‎ 2 branches 0 tags 


Switch branches/tags 2 


Find or create a branch... 


Branches Tags 
ساهمة تمت من‎ 


default 


test-branch 


lerstand املا‎ 
View all branches 


مخطط عمل جيت هب GitHub Workflow‏ 

لا أو مرنة بحیث لا تفرض على مستخدمها أية قیود في ما یتعلق بكيفية استخدامها و توظیفها 
ضمن فريق العمل» قامت بعض الشرکات بعمل معاییر 503002705 لاستخدام ا9ء و لعل آشهرها 
هو مخططات عمل طبابان۵ أو ۷۷۵۳۱۵۸ طط Gi‏ و الذي برکز على توظیف امکانیّات ]91 
و G1٥‏ كافة للعمل بشکل معياري في فرق العمل بحيث لا یحتاج المساهمون الجدد أو 
الموظفون الجدد إلى كثير من الشرح للبدء بالمساهمة الفعلية في المشاریع. 

يركز أسلوب العمل هذا على الاستخدام المكتّف للفروع بحیث يمن الفرق من اختبار التعدیلات و 
المزایا الجديدة بحربة و نشر البرمجیات ]060۱0۲6۳ بانتظام» و فكرة عمل هذا المخطط كما 


يلي: 


1 انشاء فرع جدید: ينشئ عضو الفریق فرعاً جديداً بهدف عدم التأثير على الفروع الأخرى 
المستقرة» عادة تکون الفروع المستقرّة بأسماء ۲۱25/6۲ الذي یستعمل للبينة الانتاجية 
۳ و 6۷6۱00 الذي یستعمل لبيئات التطويرء أو اختبارات ضمان الجودة 
۵4 أو تجارب العملاء المبكرة 5۱20109. 

2 إيداع المساهمات: یقوم عضو الفریق بإيداع المساهمات الخاصة بمهمته ضمن الفرع الذي 
أنشأه في الخطوة السابقة. 

3( فتح طلب سحب ۲6۵65 االا۳: في تاناا 60 طلبات السحب ۳6۵۱۵5 اا۴ هي 
عملية دمج معلّقة تتطلب مراجعة المساهمات من قبل واحد أو أكثر من عضاء الفریق و 
الموافقة علیها قبل أن يتم دمجهاء و في بعض البيئات تسمّی طلب دمج ۲/6۲9۵ 
۳6۵51 - و المقصود بها هنا أن عضو الفریق انتهی من المساهمات في فرعه و الآن 
يطلب من فریقه الموافقة على دمجها مع فروع المشروع المستقرة بهدف نشرها. 

4) مرحلة المراجعة ۳6۷16۷ 0006: تابعة للمرحلة السابقة حیث يقوم أعضاء الفریق 
الآخرون (آو قادته) بمراجعة المساهمات التي طلب زمیلهم دمجهاء و عادة ما تحدث 
نقاشات مفيدة و إيجابية هنا لتحسین جودة المساهمات. 


5) مرحلة الدمج و النشر : يتم دمج الفرع المطلوب و نشره ۲26007 بشکل آلي أو يدوي . 


خدمة وعو۳2 214110117 لاستضافة صفحات الویب 

تتیح منصة 601۳۱10 خدمة استضافة صفحات الویب الموجودة في مستودع بعيد مباشرة على 
i‏ و ذلك من خلال انشاء مستودع عام جدید و تسمیته باسم ۱56۲۳۵۳۱6۰9[0۷/0.10 
حیث أن ۷567۳2۳06 هو اسم المستخدم الخاص بك. 

بهذه الطريقة و بمجرّد دفعك لأيّة صفحات ويب إلى هذا المستودع البعید ستکون هذه الصفحات 
متاحة للعموم و كأنتها مستضافة على 56۳۷6۲ ۷60 و برابط مباشر من ۳۵965 لا یمکنك 


العثور عليه من تبودسب صفحات جیت هب في (عدادات المشروع. 


الاشتقاق في 1011111 

تتيح منصة ان1]]أ© لمستخدميها اشتقاق مستودعات جديدة خاصة أو عامة من مستودعات 
المستخدمين الآخرين العامّة» و ذلك بواسطة الأمر 10۳6 الذي يسمح لك بالبدء بمستودع جديد بناء 
على ما تم بالفعل في مستودع مشروع آخر سواء كان المشروع الآخر مملوكاً لك أو عامَا. 

على أن 1011 نفسها ليست أحد الأوامر في نظام ][0» بل هي خاصية توفرها منصة اب0۳ و 
المنصات المشابهة 

لاشتقاق مستودع ما يمكنك بكل بساطة الدخول إلى المستودع المطلوب ثم الضغط على زر ۳0۲۲ 
الذي توضحه الصورة التالية. 


© torvalds | linux Publie OWatch ب ۰ عق‎ Fork 433k ۲ 5۱: 133k 


<> Code 11 Pull requests 4 ® Actions [FH Projects O Security l< Insights 


ID dhowells and torvalds netfs: Fix gcc-12 warning by embedding vfs in... ٩۳86۵ 21 hours a90 0 
Bs ۰ 
LICE 
لا‎ 0 
01 block 
MM certs Rel 
® < 0 
نالا‎ 
۳۲ و22۵‎ 
و‎ include ١ 
لا‎ init 
لا‎ ۰ Contributors 5, 
kerme @ 
© @ 
هه یه ۰ کے‎ 


استنساخ المستودعات Repositories Clonning‏ في GitHub‏ 
لقد قمنا في الفقرة السابقة بانشاء اشتقاقنا الخاص من مستودع 0۷| مفتوح المصدر في 
طن Gi‏ غير أن ذلك المستودع لا یوجد إلا على منصة ۵(6۳!00) حالياًء و من البديهي أنّنا نريد 
حالياً مواصلة العمل عليه في مستودع 911 المحلي کون المحزّر النضي الموجود في داا۳ا6 


مناسب فقط للتعدیلات و المساهمات البسيطة جداً و ليس للتطویر الحقيقي» و لهذا تتيح Gi‏ 
و غیرها من المنضات المشابهة ميزة الاستنساخ 01000109 التي نتیح استنساخ مستود ع بعید إلى 
الحاسب المحلي» و حيث نقول استتساخ فنحن نعني ذلك لأن المستودع الذي سينشأ محليّاً سيحوي 
کامل المساهمات و الأفرع التي تمت ضمن المستودع الأصلي. 

يتم الاستتساخ من خلال الأمر 0۱006 911 ثم تمربر رابط المستودع المراد استتساخه» و للحصول 
على الرابط یمکننا الضغط على زر 6006 في لاا۳ا[۵. 


ls lssues Marketplace Ex 


ull requests O Actions [E Projects Secunty Insights 1 Settings 


master - FP 1braneh © 746‏ كل 


Mis branch is up to date with torvaldsfinux master. 


@ torvalas Morge tag ‘docs-5 19-3’ of اسهم وتو‎ 


lm Documentation Merge tag ‘docs-519-3' of git 
CensEs Add LPI 

Open wîth GitHub Desktop‏ چا سات 
Bm o 1‏ 

Releases 
= a 7 ID ممماوممة‎ zip 

O 746 gs 
0 cer 27 
- 
5 19 Packages 
- ود سم‎ 
اها‎ inciude 3 
ا‎ 

Languages 
۳6 تنك‎ 


© © © 59 05600 — -zsh - 4 


muktar/Desktop > git clone 916۵91۳۷۵۰ com:MukhtarSayedSaleh/linux.git 
Cloning into ۰ 

remote: Enumerating objects: 8841294, done. 

remote: Counting objects: 100% (279/279), done. 

remote: Compressing objects: 100% (159/159), done. 

remote: Total 8841294 (delta 194), reused 147 (delta 120), pack-reused 8841015 
Receiving objects: 100% (8841294/8841294), 3.63 GiB | 14.35 MiB/s, done. 
Resolving deltas: 100% (7338361/7338361), done. 

Updating files: 100% (76960/76960), done. 

warning: the following paths have collided (e.g. case-sensitive paths 

on a case-insensitive filesystem) and only one from the same 

colliding group is in the working tree: 


'include/uapi/linux/netfilter/xt_CONNMARK. h ' 
'include/uapi/linux/netfilter/xt_connmark. h ' 
'include/uapi/linux/netfilter/xt_DSCP.h' 
'include/uapi/linux/netfilter/xt_dscp.h' 
'include/uapi/linux/netfilter/xt_MARK.h' 
'include/uapi/linux/netfilter/xt_mark.h' 
'include/uapi/linux/netfilter/xt_RATEEST.h' 
'include/uapi/linux/netfilter/xt_rateest.h' 
'include/uapi/linux/netfilter/xt_TCPMSS.h' 
'include/uapi/linux/netfilter/xt_tcpmss.h' 
'include/uapi/linux/netfilter_ipv4/ipt_ECN.h' 
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تنبیه هام: قبل الاستنساخ تأكّد من قراءة ملف الترخیص 6 106056 فكثيراً ما يلجأ المطورون 
(المبرمجون) لاستعمال مکتبات أو آجزاء من مکتبات» أو حتی أسطر محددة من ملفات» سبق و 
أن نشرت تحت إحدى رخص البرمجیات مفتوحة المصدر دون انتباه لطبيعة الترخیص المصاحب 
لأصل الشيفرة معادة الاستخدام و انعکاسات ذلك على المنتج الذي يعمل عليه المطور» حيث أن 
ذلك قد يحمّلك عواقب و يضعك تحت التزامات قانونية» نذكر منها: 

١‏ -نشر منتجك النهائي تحت نفس الرخصة: قد يعني استخدامك لشيفرة تحت رخصة معينة أنك 
مجبر -بالقانون- على نشر منتجك النهائي عندما يجهز بشكل مفتوح المصدر و تحت نفس 
الرخصة الأصلية. 

۲ -منع الاستخدام التجاري: قد يعني استخدامك لشيفرة تحت رخصة معينة أنك مجبر -بالقانون- 
ألا تستخدم منتجك النهائي بشكل تجاري أو ربحي إطلاقاً! 

۳ -منع الاشتقاق: بمعنى السماح للآخرين باستعمال هذا المنتج 'كما هو" دون إتاحة البناء عليه 
أو تعديله أو ترجمته ... الخ» و قد يكون لهذا الأمر أثر رجعي على منتجك أنت أيضاً. 

٤‏ -إلزامية النسبة: بحيث تكون مجبراً بالقانون على ذكر اسم الشخص أو الكيان مالك الأجزاء 
المقتبسة أو المكتبات المستعملة. 

لذلك في المرة القادمة و قبل أن تقوم ب'نسخ-لصق" لأي شيفرة برمجية تجدها على الانترنت» تأكد 


من قراءة الترخيص بشكل جيد لما لذلك من التزامات قانونية هامّة قد يجهلها الكثيرون. 


000 قدمة في ]01 
مواصیع متقدمه في 


ملف التجاهل ©:510151101. 
لاشك أنه ستكون أجزاء أو ملفات من المشروع الذي تعمل عليه لا تريد مشاركتها مع غيرك ممن 
يطلع على شيفرة المشروع» و من أمثلة تلك الملفات: 


ملفات السجلات ۲۱۱68 100. 

الملفات المؤقتة files‏ ۰16۲۳۲۵0۲۵۲۷ 
الملفات المخفية. 

الملفات الشخصية. 

ملفات الكلمات السرتة و مفاتيح المصادقة. 


غير ذلك من الملفات ذات الحساسيّة. 


تستطيع أن تطلب من او أن يتجاهل تلك الملفات أو الأجزاء من المشروع التي ينبغي له تجاهلها 
باستخدام ملف 9111907016. (لاحظ أن اسم الملف يبدأ بنقطة و بالتالي سيكون مخفياً بشكل 


افتراضي في أنظمة لينكس و ماك أو إس) و لن يتعقب 911 الملفات و المجلدات المحددة في 


6 . رغم أنه يتتبع ملف 0[190076. نفسه. 

يجب أن يتم إنشاء الملف ©911190707. في أعلى مستوى من مجلدات المشروع (في المجلد الجذر 
۱ بتعبير آخر)» ثم و بعد إنشاء الملف نستخدم أي محرر نصيء و نضيف القواعد التي تحدد 
الملفات التي نرغب بتجاهلهاء و حين نقول قواعد فنحن نعني ذلك لائنا قد نكون في حالات نحتاج 
فيها لتجاهل الكثير من الملفات دفعة واحدة كتلك التي لها امتداد محدد مثلاً أو التي تطابق 
أسماؤها نمطاً معيّناً ... الخ» و فيمايلي القواعد التي نستطيع تعريفها: 


النمط 


الشرح - المطابقات أمثلة 


ملف ©0111001. 


# text comment 


name 


name/ 


name.file 


/name.file 


ليس للأسطر التي تبدأ بإشارة # 
أي تأثير في ملف 900۲6لاآو. و 
إنما تستخدم لترك تعليقات لتوضيح 


شيء ما من قبل المطوّرين عادة 


جميع ملفات 73006 و مجلدات 
۵6 و الملفات و المجلدات 


التي في أي مجلد ۲۵۲06 


الانتهاء بالشرطة المائلة 51351 
يشير إلى أن المطلوب مطابقته 
هو المجلد المذکور» و يطابق 
جميع الملفات و المجلدات في أي 


مجلد ©0310 


۱7۱۰ 6 


إلى أن ال نمط یطابق الملفات 
الموجودة في المجلد الجذر فقط و 


هو مجلد ]۲00 


/name.log 
/name/file.txt 


/lib/name.log 


/name/file.txt 


/name/log/name.log 


عدم وجود تطابق: 


/name.log 


/name.file 


/lib/name.file 


/name.file 


عدم وجود تطابق: 


/lib/name.file 


lib/name. file 


* * /lib/name.file 


* * Iname 


/lib/** 6 


*file. 


يحدد النمط الملفات في مجلدات 
بعينهاء لتكون منسوية دوماً إلى 
المجلد الجذر حتى لو لم نبدأ 
بالشرطة الدالة على المجلد الجذر» 
و هي الشرطة المائلة / 

الابتداء بعلامتي النجمة ** قبل 
الشرطة المائلة / يحدد أن النمط 
یطابق أي مجلد في المستودع و 
لیس المجلد الجذر فقط 


جمیع مجلدات 08006 و أي 
ملفات أو مجلدات في أي مجلد 


name 


جميع مجلدات ©7317 و الملفات 
و المجلدات في أي مجلد 0231076 
ذاخل مهد ناا 


جميع الملفات ذات الامتداد 1/6. 


/lib/name.file 
عدم وجود تطابق:‎ 
۱۳6 


/test/lib 6 


/lib/name.file 


/test/lib 6 


/name/log.file 
/lib/name/log.file 
/name/lib/log.file 


/lib/name/log.file 

/lib /test/name/log.file 
/lib/test/ver1 /name/log.file 
عدم وجود تطابق:‎ 


/name/log.file 


/name.file 


/lib/name.file 


*name/ 


name?.file 


name[a-=-z].file 


name[abc].file 


name[!abc].file 


* .file 


name 


غير محدد. 


محدد» و يكون المحرف فى تلك 
الحالة حرفاً من 2 حتى ۰2 أو 


رقماً 


يطابق محرفاً واحداً في مجموعة 
محددة من المحارف» و فن تلك 
الحالة يكون المحرف أحد الحروف 


الثلاثة 2 أو 0 أو © 
با ا و 


المحارف المحددة في مجموعة و 
هي a-b-c‏ في تلك الحالة 


جميع الملفات ذات الامتداد 1/6. 


/lastname/log.file 


/firrstname/log.file 


/names.file 
/name1..file 
عدم وجود تطابق:‎ 


/names1.file 


/names.file 
/nameb.file 
عدم وجود تطابق:‎ 


/name1..file 


/namea.file 


/nameb.file 


عدم وجود تطابق: 


/names.file 


/names.file 


/namex.file 


عدم وجود تطابق: 


/namesb.file 


/name.file 


name/ 


!name/secret.log 


* 6 


!name.file 


* .file 
!name/*.file 


junk.* 


ENS 
باستثاء‎ ٣4۳8 في أي مجلد‎ 


name/secret.log 


تحدد العلامة ! نفياً أو استثناع» و 
تطابق جمیع الملفات ذات الامتداد 


name.file باستتتاء‎ 6 


إضافة أنماط جديدة بعد النفي 
سيعيد تجاهل ملف تم تجاهله من 
قبل. جميع الملفات ذات الامتداد 
65 باستثناء تلك التي في مجلد 
6 إلا إذا كان اسم الملف 


junk 


/lib/name.file 


/name ۱‏ 
/name/log/name.log‏ 
عدم وجود تطابق: 


/name/secret.log 


/log.file 
/lastname.file 
عدم وجود تطابق:‎ 

/name. file 
log.file 
/name/log.file 
عدم وجود تطابق:‎ 


/name/junk. file 


فائدة: يوجد موقع لطيف جداً اسمه 105://9100۳6.10! يعطي قوالب جاهزة لملفات 
6 او مناسبة لكل لغة برمجة أو إطار عمل شهير لتسريع إعداد ما يجب تجاهله. جرّبوه! 


السفر في الزمن مع 006016006 git‏ 
نستطیع باستخدام 911 أن نعید عقارب الساعة إلى الوراء مجازياً» بمعنی أنّ نعيد الملفات الموجودة 
في المستودع إلى الحالة التي كانت فیها لحظة مساهمة ما تماماًء و ذلك من خلال الأمر ]او 


checkout‏ ثمّ ذكر معرّف المساهمة المطلوب العودة إليها. 


git checkout <commit-id> 


الأمر Reset‏ 
ذكرنا في الفصل الأول أنه توجد طريقة ثانية متقدّمة للتراجع عن مساهمة أو أكثر قمنا بهاء و قلنا 
أتنا سنغطيها في الفصل المتقذم» و الآن قد حان الوقت للحديث عنهاء ألا و هي طريقة الأمر 

.reset 
يُستخدم الأمر 8561 عند الرغبة في إرجاع المستودع في التاريخ إلى مساهمة سابقة و له ثلاثة‎ 
أنماط:‎ 
النمط الخشن 02۳0--: و هو أخطر الأنماط حيث أنّه يعيد المستودع إلى مساهمة سابقة‎ .1 
مع إلغاء جميع المساهمات و التغييرات التي حدثت بعد تلك المساهمة.‎ 


git reset --hard <commit-id> 


2. النمط الناعم 5016--: و هو شبيه بالسابق إلا أنه لا يلغي المساهمات التاليةء بل يبقيها و 


کأتھا تمت و تم عمل 200 لها اما لم يتم عمل ]00۳0۳0 (و لهذا اسمه سوفت). 


git reset --soft <commit-id> 


3. النمط الوسطي ۳0[60--: شبيه بالنمط الناعم مع فارق أنه يبقي التغييرات و كأتها حدثت 
للتو و لم تسجّل في تاريخ المستودع بعد» و بالتالي إذا أردت الاحتفاظ بها فيجب أن تقوم 


.git commit بعمل 200 011 ثم‎ 


git reset --mixed <commit-id> 


اعتراف: شخصياً فكثيراً ما أستعمل هذا النمط للتراجع عن بعض المساهمات التي أضطر للقیام بها 
على سبيل التجرية أو لأسباب أخرى قبل الانتهاء الفعلي من العمل على ميزة ما. 

على أيّة حال» و بغفض النظر عن النمط الذي تريد استخدامه فيجب آوّلاً أن تقوم بتحديد المساهمة 
التي ترغب في العودة إليها (من خلال تحديد معرّفها ۱0 00۳0۳۳ من خلال الأمر 09 انو أو 
.(gitk‏ 

يوضّح الشکلان التخیّلیان التالیان ماذا يحدث عند القيام بالشر ۳270-- ۲۵56۵1 011 حيث تمتّل 


کل دائرة مساهمة ما ]00۲۲۳۱۱ 


کم 
4-۰ ) 


إذا كان في المستودع أريع مساهمات كما يوضّح الشکل آعلاه و أحببنا العودة إلى المساهمة الثانية 
بشکل خشن 03۲0-- فاتنا فعليّاً نتخلّى عن المساهمتین التالیتین و یصبح شکل المستودع حالياً 
كما في الشکل آدناه. 


ملحوظة: آنصح بشدّة لمن يرغب بفهم 914 في العمق أن يمضي بعض الوقت في موقع او 
0 02 حيث يعطيك تصوراً ممتازاً عمَا یقوم به کل آمر بشکل مرئيء و بالمناسبة هذا 


الموقع هو مصدر الشکلین أعلاه. 


استخدام 20000-- commit‏ 
أحياناً و لسبب ما قد نرغب بتغییر ما قمنا بالمساهمة به مؤخَراء و هو ما يتيحه الأمر او 
--amend‏ 00۳۳ مع التنبیه أن هذا الأمّر لا يغيّر المساهمة الأصليّة و لنما یجمع أيّة 
موجودة حالياً في بيئة الادراج )6۳۷۱۳0۳۳06۳ 51990109 مع آخر مساهمة و ينشئ من کلیهما 
مساهمة جديدة كليّاًء نذکر هذا لأنّ استخدامه يعني تغيير معرّف آخر مساهمة ۱0 60101011 و 


لذلك وجب التنبيه. 


0 ]نع حان وقت لوم أحد ما! 

أحياناً نرغب و لسبب ما بمعرفة من هو المساهم الذي تسبب بتغيير سطر ما من ملف ما أو 
مجموعة أسطرء يتيح لنا أو ذلك من خلال الأمر 513076 او و آری تسميته طريفة لأنّ ۱2۲۳06 
باللغة الإنجليزية تستعمل في الحالات السلبيّة لإلقاء اللوم على أحد ما. على أيّة حال» صيغة الأمر 
هي 


git blame ا-‎ <start>,+<end> -- <file-path> 


حيث أنّ 51214 هو رقم السطر» و 600 هو عدد الأسطر التالية في حال أنّنا نرغب بالاستعلام 
عن كتلة أسطر و لیس سطراً واحداً» و 16-0910 هو مسار الملف الذي نستعلم عنه» تظهر 
الصورة التالية الملامة الواقعة علي في تعدیل السطر رقم ۳ من الملف ۰۱06.۳۱ 
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Desktop/git-book - (master) > git blame -L 3,+1 -- index.html 
^f1d5d3e (Muktar SayedSaleh 2022-06-09 11:15:51 +0300 3) مرحباً بك في<1116+>‎ git !>/ti1t1ع<‎ 


Desktop/git-book - (master) > 


۷ )نع متی حدث هذا؟ 

أحياناً نرغب و لسبب ما بمعرفة ما هي المساهمة التي تسببت في حدوث مشكلة ما أو تغییر ما 
في المشروع الذي نعمل علیه. و في حالة المشاریع الکبيرة ذات التاریخ الطویل قد يشكل هذا تحذّياً 
إذا كان يعني مراجعة المساهمات واحدة واحدة. 

لحسن الحظ توفر 911 آليّة لتوظیف خوارزميّة البحث الثنائي 962700 817317 في المساهمات 
للوصول بشکل أسرع بکثیر إلى المساهمة المطلوية و تحدید آلية الاستجابة لها. 

و بما أتني أكتب هذا الکتیّب على نيّة الصدقة و بهدف أن يورّع إلكترونيّاً و بشکل مجّاني في 
نهاية المطاف. فسأخالف المعهود قلیلاً في مثل هذا السیاق» و أحيلك إلى الفیدیو التالي الذي يشرح 


الأمر بمنتهی الروعة و ذلك لأنّ المتعلم لهذا الأمر یحتاج أن يراه بشکل تفاعلي برأيي. 


و الآن» ماذا بعد؟ 
لا آزعم أتني قمت بتغطية كافة الأوامر الموجودة في ]نو لكتني أرى آتني غطيت القدر الكافي 
الذي يسمح للمتعلّم الجديد الاستفادة من هذه الأداة في عمله اليومي و ما بقية أوامر أا فيمكن 
الرجوع إلى الموقع الرسمي للاداة للحصول على شرح مبسّط يشرح كل أمر من خلال الرابط التالي 
في حال الحاجة لذلك. 
شكراً لكم و الحمد لله الذي منّ علينا باتمام هذا الكتيّب» أرجو ألا تتردّدوا في التواصل معي في 


حال الرّغبة» و إلى اللقاء فى كتيّبات أخرى قادمة باذن الله. 


تم بحمد الله 


الفهرس 


أساسيات زو اذ[ 1 A [ [ [ [| E‏ 
ما هي ازع ؟ ا ل ل ل لان ا ی ل ا ا ا ا ل که 
كيف نشأت :ع و لماذا؟ لا م ل كول ا اع اه نج ره 
لماذا تستخدم غزم؟ اخ ا و ان ع خا و Beads‏ 
تثبیت ااو: GO O O‏ 
تعردف حساب 1اع المحلي Tea‏ 
البدء باستخدام اأع 89ب :ظ 
حالات الملفات ف git‏ ی ی و ی 2:57 
مرحلة الإدراج وم1ع512 TOS I OS O SE OS‏ 
یداع المساهمات Committing‏ لع ان توا هام ما لاا اه ما ی تام ا 4 اقوبه 11 
إيداع نفس الملف مرّة آخری! Dees ash‏ 
الاطلاع على سجل الإيداعات OEE‏ 13 
التراجع عن عملية إيداع في اع DEEDES SS‏ 35 

التفربعات Branches‏ ا Reed‏ و 17 
ما هي التفریعات branches؟ E‏ 
إنشاء فرع جدید في ؛اع Dea‏ ی IE. SSS‏ 
الانتقال إلى فرع آخر في ام ی 19 
فرع الإصلاحات الطارئة ءم×ا؟ :هنا DDE‏ 
دمج الفروع في 616 ی ل وس ی و ام ا 22 
حذف الفروع في ؛اع ا ی کیک هم [ز [ [ [ 1 1 1 شش 23 
تعارض عملیات الدمج Merge conflicts‏ 121 ل DADS‏ 
حل التعارض Conflict Resolve‏ هداعا عم ایو یه و اه اه بای ماه او واه ام سیب 25 


مدخل للی GitHub‏ 001010101 اا 


+ع آداة عمل موزع Distributed‏ ااا 1 1 و ی DE‏ 
تسجيل حساب جديد في دای ا انكل ا SRE‏ ول ا 9 2 
إنشاء مستودع على طن0اغ1© ا ل لل ا د هه ای و ولا اا لا ی ا میم 29 
تعريف المستودع البعيد محليّاً E‏ 
إرسال تعدیلاتنا المحليّة إلى المستودع البعید اورم SOs aA‏ 
تعديل الملفات في !از مباشرة EEO EEE‏ 
جلب تعديلات المستودع البعيد إلى المستودع المحلي ااام OSS‏ 
إنشاء الفروع عه8۳۵06۳ في منصة GitHub‏ و 
مخطط عمل جيت هب GitHub Workflow‏ و ل ا 0 ا ا ا تب 3 
خدمة وءودم دبباانی لاستضافة صفحات الويب aa‏ الله و وت 9 3 
الاشتقاق في b‏ ں۸ Git‏ ا اللو ل اا ل ا Ae‏ 36 
استنساخ المستودعات SOE Enes GitHub Repositories Cloning‏ 
مواضيع متقدمة في git‏ 08[ 1[ |[ ا 
ملف التجاهل 00۲6ع۱ااع. 00 0 0 
السفر في الزمن مع :0600 git‏ تك ی یی هت بای AD RRA‏ 
الأمرغووعم 000 0 
استخدام commit --amend‏ مه ی دای هی ده ASSO‏ 
۰۵ حان وقت لوم أحد ما غبری! AS RESA‏ 
git bisect‏ متى حدث هذا؟ Aie ea Ra ASRS‏ 
والآنء» ماذا بعد؟ امع مجه ا وو طن ولاه ‏ لم ‏ لمن 1 طانم لط ع6 لول وان وله که 


